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DROP-ENABLED TABBED DIALOGS 

Priority 


This is a utility patent application that claims priority to Provisional 
Application No. 60/243,820, filed October 27, 2000. 


Field Of The Invention. 

io The present invention relates to a method, system and apparatus for 

drop-enabled "hover" tabs, also referred to as "hover tabs" or "drag-enabled 
tabs" or "drag-enabled hover tabs". 

Related Information. 

15 

Tabbed dialogues or tabbed notebooks are a widely used technique 
for organizing the contents of complex user interfaces. As employed in 
conventional graphical user interface, such as MS Windows, tabbed 
dialogs/notebooks present the user with the appearance of a stack of 

20 "sheets" (Pages, panes, panels, or other collections) with associated "tabs" 
or visually projecting areas identifying each of the sheets. Tabs may take a 
variety of visual forms and may be arrayed within the tabbed dialog/notebook 
across the top, side, or bottom, or any combination thereof. Selection of a 
tab (for example, by clicking with a pointing device) causes the 

25 corresponding sheet and its associated tab to be displayed at the front of the 
stack, hiding or obscuring in whole or in part the contents of the other 
sheets. 


Figure 6 the current state of the art. Modules are presented in floating 
30 rack lists that must each be manually created and positioned by the user 
before it can be filled. Descriptions of modules appear in a separate table 
below that is neither visually connected nor synchronized with the rack lists. 
Modules are obtained from a tree view to the right, which lists the name and 
part/order number of all Siemens PLC modules but reveals no details directly 
35 except for the selected module, which is described in a visually remote pane 
at the very bottom of the screen. Modules are parameterized through a 
separate tabbed dialog. The tabs and their contents are different for each 
kind of module. Note that the graphical form of the display simply follows 
Windows conventions with no connection to the real aspects of hardware 
40 configuration save for the tiny icons to the left of each list entry. 
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Conventional or previous versions of this technology have two 
significant shortcomings that restrict or reduce their usability and utility. First, 
they do not allow straightforward and efficient exploration of all the 
information contained in a tabbed dialog/notebook because each sheet must 

5 be selected separately and in succession (by clicking and releasing a button 
on a mouse or other pointing device, for example). Furthermore, to move or 
copy data or an object from one sheet to another within a conventional 
tabbed dialog/notebook requires a user to first select the data or object to be 
copied or moved on one sheet, then initiate a "copy" or "cut" operation, then 

io select another sheet by clicking on its tab, then select the point of insertion 
within that sheet, then initiate a "paste" operation. 


OBJECTS & SUMMARY OF THE INVENTION 


The present invention introduces an enhancement that dramatically 
improves on conventional tabbed dialogs/notebooks by enabling users to 
more simply and directly explore all the contents of a tabbed dialog/notebook 
and to more simply and directly copy or move information among sheets 
20 within a tabbed dialog/notebook. The technique is both novel and non- 
obvious, and the improvement in utility and operational ease of use is 
significant and substantial. 

This invention provides a novel form of tabbed interaction applies to 
all forms of graphical user interface features in which contents are organized 

25 into sheets, panes, panels, pages, or other visual collections identified by 
associated tabs regardless of the location, shape, or appearance of the 
associated tabs; in which some of the collections are partially or wholly 
hidden at any given time; and in which the display of the contents of any 
particular hidden or partially hidden collection is achieved by the user 

30 through interaction with the associated tab. What is provided is a non- 
obvious alteration to the behavior of the tabs in a tabbed dialog/notebook to 
overcome these limitations. 


BRIEF DESCRIPTION OF THE PREFERRED EMBODIMENTS 


Fig. 1 shows the PLC configuration; 

Fig. 2 shows a graphical representation of a PLC configuration tool; 
Fig. 3 shows a graphical representation of a PLC configuration tool; 
Fig. 4 shows a graphical representation of a PLC configuration tool; 
Fig. 5 shows a graphical representation of a PLC configuration tool; 
Fig. 6 shows the current state of the art; and 
Fig. 7 shows a graphical representation of a PLC configuration tool. 
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DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 


The present invention is applicable to all forms of graphical user 
interface features. In any event, and solely for the sake of description, the 
present invention here shall be illustrated with reference to the automation 
industry. Therefore, and before a more detailed discussion of the invention 
is pursued, the automation industry, as it particularly applies to the instant 
case, shall first be discussed. 


Most modern automation equipment is controlled by software running 
on specialized computers called Programmable Logic Controllers (PLCs). 
The systems controlled by PLCs vary tremendously, with applications in 
manufacturing, chemical process control, machining, transit, power 
distribution, and many other fields. Automation applications can range in 
complexity from a simple panel to operate the lights and motorized window 
shades in a conference room to a completely automated brewery in which 
the machinery for everything — from dispensing and mixing ingredients to 
controlling the brewing process and even filling and sealing of bottles — is 
under programmed control. 


To support such highly varied needs, companies such as Siemens 
AG produce lines of modular computer components that can be combined 
lu and configured in many different ways to monitor and operate various 

ijj 25 equipment. In a representative system (Figure 1), a Central Processor Unit 

q (CPU) is combined with a number of input/output (I/O) modules that connect 

y, with sensors and actuators in the automation equipment itself. The programs 

that run on the PLC are planned, written, and debugged by automation 
programmers using development software running on conventional desktop 
30 or laptop computers or workstations. The programs produced through this 
development software must be downloaded to the PLC itself to operate the 
equipment. 


Automation programming is an exacting engineering profession 
35 requiring great attention to detail, mastery of specialized concepts and 
terminology, and thorough and systematic discipline to avoid or eliminate 
errors. The risks associated with undiscovered errors in PLC code can be 
enormous. A lurking bug in a PLC program could destroy an expensive piece 
of material being machined, require the repair of costly equipment, or even 
40 lead to injury of personnel. 


45 
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Siemens AG provides a software application that automates 
programming, called Step 7 Lite, which is a product derived and compatible 
with the Simatic Step 7 line of IDEs for automation programming which are 
provided by Siemens AG. The system supports programming of several 
5 Siemens product lines— S7 300, ET200S ET200X series— comprising 

comparatively simple PLC components. It is intended for more or less basic 
problems at the lower end of the range of PLC applications. Of course, the 
Step 7 application is not restrictive of the scope of the invention, but is 
merely used here as an illustration to describe the invention. 


Problematically, nearly all existing IDEs for PLC programming have a 
very long learning curve. The slow accretion of features implemented by 
diverse teams at various times and the resulting lack of consistency among 
the various subsystems have added to difficulties in learning and mastery 
15 and to complications in use. Features and functionality have been the driving 
forces in PLC programming tools with relatively little attention paid to 
usability during design. Moreover, the roles of actual users and the detailed 
nature of their tasks have not been fully articulated to be reflected in user 
interface design. 

20 Thus, the introduction of Step 7 Lite system is to primarily provide 

immediate usability by qualified but inexperienced users. In addition, the 
application offers flexible accommodation to a wide range of work styles and 
programming practices. With the Step 7 Lite, users experience a reduction 
of user errors. Another aspect is that Step 7 Lite increases in productivity 

25 through reduced user steps as well as reduced errors. Thus, there is a 
closer fit between the user interface and the way actual PLC programmers 
think and work. Therefore, leading to simplification of tasks where consistent 
with the need for great flexibility and with recognition of the inherent 
complexity and unpredictability of the PLC programming process. 


In order to achieve the necessary high-levels of usability, flexible 
support, and performance efficiency, Step 7 Lite was developed through 
usage-centered design, a systematic model-driven process for designing 
applications based on the structure of user tasks. At the core of usage- 
35 centered design is a comprehensive and fine-grained task model 

representing user intentions and system responsibilities in the form of so- 
called use cases. This task model guides every aspect of the visual and 
interaction design for the user interface, including the design of custom 
components and novel behaviors. 


At any rate, Step 7 Lite is an off the shelf system that needs not to be 
described in full detail here and any manuals which are available to the 
public regarding the intracacies of Step 7 are incorporated herein by 
reference. Suffice to say that a significant part of the process of 
45 programming an automation solution involves interactions between the 
programming system— the Step 7 Lite IDE in this case— and the particular 
configuration of hardware PLC components employed in the application 

Express Mail Label No. EL823501801 4 


2000 P 09015 US 01 


In order to make full use of all features in the hardware, the IDE must 
know what modules are incorporated in the equipment and how they are 
interconnected. The process of setting up the IDE to conform to the PLC 
5 hardware in use is called hardware configuration. The IDE must be manually 
configured for the target PLC hardware because the actual hardware may be 
at a separate location or may not even exist when programming is begun. In 
practice, it is complicated for the user to configure the target. Because of this 
complexity, hardware configuration was a prime concern in designing the 
10 invention and, for that reason especially, the invention has in mind use by 
less experienced programmers building applications of limited sophistication 
on relatively simple components. 


The design of the Step 7 Lite support for the hardware configuration 
15 process is best understood within the context of the larger system. To 
promote productivity by PLC programmers, STep 7 Lite uses a flexible, 
multilevel navigation scheme offering simple, rapid access to any and all 
relevant views of the PLC application underdevelopment and direct 
switching among the various tasks of PLC programming (Figure 2). A project 
20 navigator on the left gives access to sets of related views and task contexts, 
which are accessible through tabs toward the bottom of the screen. This 
scheme also minimizes window-management overhead, such as rearranging 
and resizing overlapping windows. 


25 Recognizable physical and symbolic representations of actual 

equipment are used where appropriate to speed learning and reduce the 
probability of errors. This is not the silly or gratuitous use of "real-world" 
metaphor, as in Microsoft's infamous "Clippy" Office Assistant, but selected 
and carefully reasoned use of direct correspondence between the IDE and 

30 actual physical elements. For example, the control panel in the upper left of 
Figure 2 mirrors the appearance and behavior of the actual front panel on 
Siemens CPU modules. 


A novel performance-support feature employed throughout the Step 7 
35 Lite system is the "cascading" tool tip (e.g., lower left of Figure 2). Ordinary 
Windows-style tool tips provide only the briefest of messages. These may be 
adequate for simple identification of elements on a user interface, but often 
do not provide enough help or guidance for beginners. Cascading tool tips 
provide an added, more detailed or more advanced comment after an 
40 additional short delay. In Step 7 Lite, this secondary tip usually also includes 
an additional link into an appropriate entry in the main online help system. 
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Because configuring the hardware is required at the start, a new 
project begins with the Hardware Configuration view showing, as in Figure 2. 
Hardware configuration can also be revisited by the PLC programmer as 
needed at anytime. The hardware configuration process involves several 
5 distinct but interrelated subtasks. The modules to be included in the actual 
hardware are to be selected from among the available modules in the three 
series supported by Step 7 Lite. These include power supplies, CPUs, 
analog input and output, digital input and output, and specialized interface 
modules. In the actual equipment, the modules plug into specialized racks. 
10 The corresponding software representations within Step 7 Lite must be 
similarly located and interconnected. In addition, hardware modules have 
programmable settings or parameters whose values must be set in order to 
make use of the various features of the hardware. 


15 The hardware racks are represented graphically to the left of the 

Hardware Configuration pane, with a tabular format provided in the upper 
right. The tabular display presents details regarding each included module 
while the graphic display corresponds to the physical arrangement and 
appearance of modules within racks. The two views are synchronized, 

20 allowing users to manipulate or review the configuration within whichever 
view is most convenient or best fits their style of interaction. A graphic 
element (the blue line, Figure 3) connects the two views, thus enhancing the 
visual correspondence and facilitating interpretation by the user. This visual 
element, which follows the user's actions dynamically reduces the chances 

25 of the user accidentally manipulating the wrong component. 


In the lower right is a catalog of available components from which the 
hardware configuration can be constructed. The terms and abbreviations — 
such as PS, CPU and so on— are the familiar jargon of PLC programmers 
30 and Siemens users; the order of the catalog tabs reflects a natural but not 
required order for task performance. The closed cover of the catalog allows 
selecting the component series of interest and provides a "starting hint" for 
the first-time user. A Windows XP-style one-time "balloon help" may be 
employed as a substitute. 


Inside the catalog (see Figure 3), the user has full control over the 
level of detail in presented information. Pop-up "tool tips" provide additional 
information when the user pauses over a catalog entry. Components can be 
inserted, copied, deleted, or moved within either the graphical or tabular view 

40 using any applicable standard Windows interaction idiom, such as drag-and- 
drop, copy-and-paste, target selection and double-clicking. However, the 
actual placement and interconnection of modules in real equipment is 
restricted by complex constraints, such as power supplies can only work in 
the first slot of a rack, multiple racks must be interconnected by certain 

45 interface modules that can only go in slot 3, etc. Step 7 Lite understands all 
these rules as well as the functions and characteristics of all supported 
modules, providing direct visual guidance to users. 
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For example, when a module is dragged within the graphical rack 
area, slots change appearance ("dynamic affordances and constraints") to 
indicate where the particular component can or cannot be inserted (see 
5 Figure 4). This supports correct novice performance without interfering with 
highly experienced programmers who already know all these rules. In any 
case, incorrect operation is almost completely prevented. The system is also 
smart enough to allow expert users to rapidly and correctly accomplish a 
series of insertions in successive slots just by double-clicking or pressing the 
10 <Enter> key on a selected module in the catalog. 


To see and set parameters, modules can be "opened" by double- 
clicking or by selection and then clicking on the Module Parameter button 
(supporting expert and novice performance respectively). The scrolling 

15 control surface of the parameterization dialog (Figure 5) supports a single 
navigation and interaction scheme for any set of parameters, which can 
range from a single parameter to hundreds and come in many different 
formats. User errors in parameterization are highlighted in place and 
explained in a highlighted message bar that rolls down from the lower edge 

20 of the dialog box. Thus feedback to the user is provided in context without 
overlaying or interrupting the visual context. 

Browsing the contents of drop-enabled hover tabs will now be 
described. When a tab first receives focus, such as by a button-down 
condition from a pointing device positioned within the area bounded by the 

25 tab, the corresponding sheet becomes immediately selected and visually 
comes to the front of the stack of tabbed pages; if the mouse pointer leaves 
the area bounded by the tab and corresponding sheet before the button is 
released, the tabbed page is restored to its original position in the stack of 
tabbed pages; if the button is released while the mouse pointer is within the 

30 area bounded by the tab and corresponding sheet, the tab and sheet remain 
at the front of the visual stack. From the point of view of the user, the 
resulting behavior allows the user to browse or scan through all the contents 
of the tabbed dialog/notebook merely by clicking (mouse-down) on one of 
the tabs and moving the mouse pointer across the tabs. As soon as the 

35 mouse pointer leaves the area bounded by one tab and enters that of 
another, the former is restored to its original position and the latter is 
displayed at the front of the stack, visually replacing the former. 

Drag-and-drop using drop-enabled hover tabs will now be described. 
Copying or moving data or objects between sheets in a tabbed 
40 dialog/notebook is vastly simplified by the same mechanism. If the mouse 
pointer moves over a hover tab while an object is being dragged (with a 
button held down), the corresponding sheet is immediately displayed at the 
front of the stack, allowing the user to continue to drag the object to the 
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desired location within the tab. Thus a single continuous operation (drag- 
and-drop) replaces four separate user actions (copy/cut, select tab, select 
location, paste). Drag-and-drop is not only more efficient, but is also more 
natural and intuitive for users than copy/cut/paste. If the user releases the 
5 button while the pointer is still over the tab (rather than positioned within the 
main area of the corresponding sheet), the dragged object is automatically 
inserted in some location within the sheet determined by rules and 
conventions particular to the program or the tabbed dialog/notebook (such 
as at the end of a list or in the first empty slot, etc.) 

10 

When a user wishes to perform a drag-and-drop action in which an 
object can be dropped onto several visible areas and the drop permission 
depends on external conditions, with current systems the user can only 
determine whether a drop is possible when the drop object is positioned over 
15 one of the possible areas. In the past, this problem was resolved by 
p: changing the mouse pointer into a "No Go" sign when it is not possible to 

drag-and-drop an object onto another object. Problematically, this forces the 
2 user to test several possible objects and to initially drag the object over these 

m other areas in order to find a place where a drop is possible. 

■h 20 

p;i The present invention provides a unique drag-and-drop shown in 

s' Figure 7 that, when a drag-and-drop action is initiated, other surface 

H components indicate whether or not they are able to accept the object to be 

dropped directly at the very moment when the drag-and-drop action is 
fi{ 25 initiated. The rule that the invention implements for permitting or prohibiting 

%l a drop is executed at the beginning of the drag-and-drop action initiated by 

the user, by mouse-clicking on the object to be dragged, for example. Thus, 
the drag-and-drop action is shown as a visual drop permission or prohibition 
in the relevant drop areas, such as a visual queue, for example, check mark, 
30 etc. In the preferred embodiment, and upon initiation of the action, the 

surface components display which areas, parts, elements or substructures 
can or cannot accept a given object or data element before a mouse pointer, 
arrow or cursor reaches or moves over the relevant areas, parts, elements or 
substructures. Advantageously, the user realizes directly at the beginning of 
35 the drag-and-drop action that the dragged object can be dropped. 

Therefore, with the present invention, there is no need to "test" various other 
objects to find a place where a drop is possible. Additionally, the user is 
given information as to where other objects may be dropped. This is 
advantageous for designing a lay out on the fly, giving the user pre- 
40 information where other objects may be dropped. 


In another aspect of the invention, there is provided a means for 
dropping an object into a register that is not apparent on the screen, i.e., a 
concealed register. In the past, a drag-and-drop action in which the user 
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intended to drop an object in a concealed register necessitated the halting of 
the drop procedure. After which, the concealed register must be brought to 
the foreground and, finally, the drag-and-drop action must be repeated. In 
other words, a drag-and-drop operation between the individual pages of a 
5 registered dialog was completely impossible. 


In the present invention, a drag-and-drop procedure does not need to 
be interrupted. In other words, the drop procedure to a concealed register 
can be accomplished during a registered dialog in a single closed handling 

io sequence. In more detail, when the mouse cursor is moved over the register 
of a register dialog once a drop-and-drag action has been initiated, then the 
register under the mouse cursor is automatically moved to the foreground 
after a variable time interval, and the contents can thus be seen. Process of 
making the item visible is initiated just by locating the mouse over the 

15 register of the concealed registered dialog. The invention can be extended 
to normal mouse movements (that is to say that other than drag drop.) 
Dropping an object on to a drop destination in a concealed register of a 
register dialog for drag and drop actions and drag and drop between the 
registers of a tabbed dialog or the pages of a workbook (such as the various 

20 tables in Excel, for example.) Of course, the invention can be applied to all 
controls with registers, tabs, etc. 


The present invention applies to any form or style of tabbed 
dialog/notebook presentation with any form of tabs using pointing device 

25 used with any number of buttons any of which are used alone or in 
combination or along with any keyboard keys (e.g., Alt, Ctrl, etc.). In 
addition, the present invention is applicable to application over networks, 
such as the Internet. For example, the invention is displayed through a web- 
browser and the information relating to the automation equipment is 

30 downloaded through the Internet. 


By basing the design directly on a comprehensive and detailed task 
model, the user interface is able to offer users both highly structured 
guidance and complete performance flexibility along with improved 

35 performance efficiency. This approach also allows a single interface to be 
equally well suited to the needs of the rank novice and to those of the more 
experienced or expert user. Through guidance that is both intrinsic and in 
context, subtle help and reinforcement are provided for the beginner without 
getting in the way of those with more advanced needs and skills. Everything 

40 the user of any skill level needs in terms of tools and materials as well as 
guidance and feedback is provided in one readily comprehended context. 
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